import wxValidate from 'wechat-validate'
Page({
  behaviors: [wxValidate],
  data: {
    dateLayerVisible: false,
    houseLayerVisible: false,
    houseList: [],
    currentDate: Date.now(),
    maxDate: Date.now() + 1000 * 3600 * 24 * 3, //最大时间
    houseInfo: '', // 选择的房屋名称
    // 准备表单数据
    houseId: '', // 选择的房屋ID
    name: '', // 访客姓名   【新增】
    gender: 1, // 访客性别 【新增】
    mobile: '', // 访客手机号 【新增】
    visitDate: '',
  },
  rules: {
    name: [
      { required: true, message: '访客姓名不能为空!' },
      { pattern: /[\u4e00-\u9fa5]{2,5}/, message: '访客姓名只能为中文!' },
    ],
    mobile: [
      { required: true, message: '访客手机号不能为空!' },
      { pattern: /^1[3-8]\d{9}$/, message: '请填写正确的手机号码!' },
    ],
    houseId: [{ required: true, message: '请选择到访的房屋!' }],
    visitDate: [{ required: true, message: '请选择到访的日期!' }],
  },
  onLoad() {
    this.getHouseList()
  },

  // 获取房屋列表
  async getHouseList() {
    let houseList = await wx.http.get('/room')
    houseList = houseList.map((item) => ({
      name: item.point + item.building + item.room,
      id: item.id,
    }))
    this.setData({ houseList })
  },
  // 选择房屋
  selectHouse({ detail }) {
    this.setData({ houseId: detail.id, houseInfo: detail.name })
  },
  // 选择了日期
  selectDateInfo(event) {
    console.log(event)
    this.setData({
      visitDate: wx.utils.dataFormat(event.detail),
      dateLayerVisible: false,
    })
  },
  openHouseLayer() {
    this.setData({ houseLayerVisible: true })
  },
  closeHouseLayer() {
    this.setData({ houseLayerVisible: false })
  },
  openDateLayer() {
    this.setData({ dateLayerVisible: true })
  },
  closeDateLayer() {
    this.setData({ dateLayerVisible: false })
  },
  // 提交表单数据
  async goPassport() {
    // 验证表单数据
    if (!this.validate()) return
    // 提交数据
    const { name, gender, mobile, houseId, visitDate } = this.data
    const res = await wx.http.post('/visitor', { name, gender, mobile, houseId, visitDate })
    console.log(res)
    // 提示成功
    wx.utils.toast('操作成功')
    // 跳转页面
    setTimeout(() => {
      wx.reLaunch({
        url: '/visitor_pkg/pages/passport/index?id=' + res.id,
      })
    }, 300)
  },
})
